- 
                Notifications
    You must be signed in to change notification settings 
- Fork 35
          schemaview.py: adding induced_slot_range function to retrieve the possible ranges for a slot
          #471
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
…et of possible ranges for a slot
| Codecov Report✅ All modified and coverable lines are covered by tests. Additional details and impacted files@@            Coverage Diff             @@
##             main     #471      +/-   ##
==========================================
+ Coverage   77.52%   77.63%   +0.11%     
==========================================
  Files          52       52              
  Lines        4493     4512      +19     
  Branches      978      984       +6     
==========================================
+ Hits         3483     3503      +20     
  Misses        788      788              
+ Partials      222      221       -1     ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
 | 
| "induced_slot_range", | ||
| "induced_range_strict", | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
two new elements here -- testing the induced_slot_range function and induced_slot_range with the strict kwarg set
| (sv_range, range_tuple) = sv_range_riid_gen | ||
|  | ||
| slots_by_name = {s.name: s for s in sv_range.class_induced_slots("ClassWithRanges")} | ||
| slot_object = sv_range.induced_slot(slot_name, "ClassWithRanges") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
was
slots_by_name = {s.name: s for s in sv_range.class_induced_slots("ClassWithRanges")}No real need to generate induced slots for all the slots in ClassWithRanges -- just generate the induced slot for the slot under investigation.
| if slot_range: | ||
| return {slot_range} | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unlike slot_range_as_union, if the slot range is None, this function does not return [None]; it returns an empty set. If the slot range is defined, it returns a set containing that range.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Awesome!! looks like this new induced_slot_range() method is an improvement on slot_range_as_union(). The validation checks in "strict mode" are very useful, and the method not returning None for range is a great improvement too 🚀
Not a blocker for this PR, but going forward should we start marking certain methods as "deprecated", like for example in this case where induced_slot_range() can replace slot_range_as_union()?
Similar in function to
slot_range_as_unionbut performs a number of checks and removeslinkml:AnyorNonefrom the results.I am not particularly stuck on the name so if anyone has a better one, go ahead and suggest it!